Paradigm(s) | Multi-paradigm: concurrent, logic, functional, imperative (object-based) |
---|---|
Appeared in | 2003 |
Designed by | Francis McCabe, Keith Clark |
Preview release | 9-30-07 (September 30, 2007 | )
Typing discipline | strong |
Influenced by | Prolog[1] |
OS | Unix-like |
License | GPLv2 |
Go! is an agent-based programming language in the tradition of logic-based programming languages like Prolog.[1] It was introduced in a 2003 paper by Francis McCabe and Keith Clark.[2]
Upon the November 2009 release of Google's Go programming language (note lack of exclamation point), McCabe asked Google to change the name of their language and accused the company of "steam-rolling over us".[1][3] The issue received attention among technology news websites, with some of them characterizing Go! as "obscure".[4]
Contents |
The authors of Go! describe it as "a multi-paradigm programming language that is oriented to the needs of programming secure, production quality, agent based applications. It is multi-threaded, strongly typed and higher order (in the functional programming sense). It has relation, function and action procedure definitions. Threads execute action procedures, calling functions and querying relations as need be. Threads in different agents communicate and coordinate using asynchronous messages. Threads within the same agent can also use shared dynamic relations acting as Linda-style tuple stores."[2]
The authors also propose that the language is suitable for representing ontologies due to its integration of logic, functional and imperative styles of programming. [5]
As a deliberate design choice to reduce complexity, Go! does not support inheritance. Thus, it is an object-based language rather than a true object-oriented language.
The following example illustrates the "ontology-oriented" type and declarations style of Go!:[5]
Gender::= male | female. person <˜ {dayOfBirth:[]=>day. age:[]=>integer. gender:[]=>Gender. name:[]=>string. home:[]=>string. lives:[string]{}}. person:[string,day,Gender,string]$=person. person(Nm,Born,Sx,Hm)..{ dayOfBirth()=>Born. age() => yearsBetween(now(),Born). gender()=>Sx. name()=>Nm. home()=>Hm. lives(Pl) :- Pl=home(). yearsBetween:[integer,day]=>integer. yearsBetween(...) => .. }. newPerson:[string,day,Gender,string]=>person. newPerson(Nm,Born,Sx,Hm)=>$person(Nm,Born,Sx,Hm).
The ::=
rule defines a new algebraic data type, a data type with only data constructors.
The <˜
rule defines an interface type - it indicates what properties are characteristic of a person
and also gives type constraints on these properties. It documents that age
is a functional property with an integer value, that lives
is a unary relation over strings, and that dayOfBirth
is a functional property with a value that is an object of type day
.
The $=
type rule indicates that there is also a theory label, with the functor person
, for a theory that defines the characteristic properties of the person
type - implements the person
interface - in terms of four given parameters of types string, day
, Gender
, and string.